package com.bot.nft.module.op.mapper;

import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Constants;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.bot.common.mybatis.core.BaseMapperPlus;
import com.bot.nft.module.op.domain.OpAirList;
import com.bot.nft.module.op.domain.bo.OpAirMbHoldBo;
import com.bot.nft.module.op.domain.vo.OpAirListVo;
import org.apache.ibatis.annotations.Param;

import java.util.Collection;
import java.util.Date;
import java.util.List;
import java.util.Set;


/**
 * <p>
 * 空投活动白名单Mapper 接口
 * </p>
 *
 * @author zhangkaige
 * @since 2024-01-24
 */
public interface OpAirListMapper extends BaseMapperPlus<OpAirListMapper, OpAirList, OpAirListVo> {

    /**
     * 分页查询空投白名单·
     * @param page 分页信息
     * @param airId 空投活动标识
     * @param phone 手机号关键字
     * @return
     */
    Page<OpAirListVo> airListVoPage(IPage<OpAirListVo> page,
                                    @Param("airId") String airId,
                                    @Param("phone") String phone);

    /**
     * 查询用户持仓情况
     *
     * @param nftIdList 藏品列表
     * @param snapTime  快照时间
     * @return 用户持有信息集合
     */
    List<OpAirMbHoldBo> selectMbHoldList(@Param("nftIdList") Set<String> nftIdList, @Param("snapTime") Date snapTime);

    /**
     * 根据会员手机号查询会员标识
     *
     * @param phones 手机号
     * @return 白名单Vo
     */
    List<OpAirListVo> selectVoListByPhones(Collection<String> phones);

    /**
     * 根据空投活动标识查看白名单信息
     *
     * @param id 空投活动标识
     * @return 空投白名单集合
     */
    List<OpAirListVo> selectVoListByAirId(String id);
}
